aboutsummaryrefslogtreecommitdiffstats
path: root/src/pages/article/[slug].tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/pages/article/[slug].tsx')
-rw-r--r--src/pages/article/[slug].tsx17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/pages/article/[slug].tsx b/src/pages/article/[slug].tsx
index 54391fc..493f061 100644
--- a/src/pages/article/[slug].tsx
+++ b/src/pages/article/[slug].tsx
@@ -5,14 +5,19 @@ import PostFooter from '@components/PostFooter/PostFooter';
import PostHeader from '@components/PostHeader/PostHeader';
import Sharing from '@components/Sharing/Sharing';
import ToC from '@components/ToC/ToC';
+import { config } from '@config/website';
import { t } from '@lingui/macro';
import { getAllPostsSlug, getPostBySlug } from '@services/graphql/queries';
import { NextPageWithLayout } from '@ts/types/app';
import { ArticleProps } from '@ts/types/articles';
import { loadTranslation } from '@utils/helpers/i18n';
+import { addPrismClasses, translateCopyButton } from '@utils/helpers/prism';
import { GetStaticPaths, GetStaticProps, GetStaticPropsContext } from 'next';
import Head from 'next/head';
+import { useRouter } from 'next/router';
+import Prism from 'prismjs';
import { ParsedUrlQuery } from 'querystring';
+import { useEffect } from 'react';
const SingleArticle: NextPageWithLayout<ArticleProps> = ({ post }) => {
const {
@@ -27,6 +32,18 @@ const SingleArticle: NextPageWithLayout<ArticleProps> = ({ post }) => {
title,
} = post;
+ const router = useRouter();
+ const locale = router.locale ? router.locale : config.defaultLocale;
+
+ useEffect(() => {
+ addPrismClasses();
+ Prism.highlightAll();
+ });
+
+ useEffect(() => {
+ translateCopyButton(locale);
+ }, [locale]);
+
return (
<>
<Head>